| Name          |           |           |           | Fields            | fpga4studer | nt.com Comments                    |
|---------------|-----------|-----------|-----------|-------------------|-------------|------------------------------------|
| Field<br>size | 3<br>bits | 3<br>bits | 3<br>bits | 3<br>bits         | 4 bits      | All MIPS-L instructions 16 bits    |
| R-<br>format  | op        | rs        | rt        | rd                | funct       | Arithmetic instruction format      |
| I-format      | op        | rs        | rt        | Address/immediate |             | Transfer, branch, immediate format |
| J-format      | op        |           |           | target a          | address     | Jump instruction format            |

| Name                   | fpga4<br>Format | studer | it.com | Comments |        |        |                 |
|------------------------|-----------------|--------|--------|----------|--------|--------|-----------------|
|                        | Format          | 3 bits | 3 bits | 3 bits   | 3 bits | 4 bits | Comments        |
| add                    | R               | 0      | 2      | 3        | 1      | 0      | add \$1,\$2,\$3 |
| sub                    | R               | 0      | 2      | 3        | 1      | 1      | sub \$1,\$2,\$3 |
| and                    | R               | 0      | 2      | 3        | 1      | 2      | and \$1,\$2,\$3 |
| or                     | R               | 0      | 2      | 3        | 1      | 3      | or \$1,\$2,\$3  |
| slt                    | R               | 0      | 2      | 3        | 1      | 4      | slt \$1,\$2,\$3 |
| jr                     | R               | 0      | 7      | 0        | 0      | 8      | jr \$7          |
| lw                     | I               | 4      | 2      | 1        | 7      |        | lw \$1, 7 (\$2) |
| $\mathbf{s}\mathbf{w}$ | I               | 5      | 2      | 1        | 7      | 7      | sw \$1, 7 (\$2) |
| beq                    | I               | 6      | 1      | 2        | 7      |        | beq \$1,\$2, 7  |
| addi                   | I               | 7      | 2      | 1        | 7      |        | addi \$1,\$2,7  |
| j                      | J               | 2      |        | 50       | j 1000 |        |                 |
| jal                    | J               | 3      | 500    |          |        |        | jal 1000        |
| slti                   | I               | 1      | 2      | 1        | 7      |        | slti \$1,\$2,7  |

```
1. Add: R[rd] = R[rs] + R[rt]
```

2. Subtract: 
$$R[rd] = R[rs] - R[rt]$$

3. And: 
$$R[rd] = R[rs] & R[rt]$$

$$4. \mathbf{Or} : \mathbf{R[rd]} = \mathbf{R[rs]} \mid \mathbf{R[rt]}$$

5. SLT: 
$$R[rd] = 1$$
 if  $R[rs] \le R[rt]$  else 0

7. Lw: 
$$R[rt] = M[R[rs] + SignExtImm]$$

8. 
$$Sw : M[R[rs]+SignExtImm] = R[rt]$$

10. Addi: 
$$R[rt] = R[rs] + SignExtImm$$

13. SLTI: 
$$R[rt] = 1$$
 if  $R[rs] \le imm$  else 0

$$JumpAddr = \{ (PC+1)[15:13], address \}$$

BranchAddr = { 7{immediate[6]}, immediate, 1'b0 }

Control signals Instruction ALU MemRead Mem Branch ALUOp Reg Memto Reg Jump Dst Src Reg Write Write R-type LW SW addi beq j jal slti 

|        | ALU Control |        |               |              |  |  |  |  |
|--------|-------------|--------|---------------|--------------|--|--|--|--|
| ALU op | Function    | ALUcnt | ALU Operation | Instruction  |  |  |  |  |
| 11     | xxxx        | 000    | ADD           | Addi,lw,sw   |  |  |  |  |
| 01     | xxxx        | 001    | SUB           | BEQ          |  |  |  |  |
| 00     | 00          | 000    | ADD           | R-type: ADD  |  |  |  |  |
| 00     | 01          | 001    | SUB           | R-type: sub  |  |  |  |  |
| 00     | 02          | 010    | AND           | R-type: AND  |  |  |  |  |
| 00     | 03          | 011    | OR            | R-type: OR   |  |  |  |  |
| 00     | 04          | 100    | slt           | R-type: slt  |  |  |  |  |
| 10     | xxxxxx      | 100    | slt           | i-type: slti |  |  |  |  |

